package mianshi.huawei.easy;

/*
有这样一道智力题：“某商店规定：三个空汽水瓶可以换一瓶汽水。小张手上有十个空汽水瓶，
她最多可以换多少瓶汽水喝？”答案是5瓶，方法如下：先用9个空瓶子换3瓶汽水，喝掉3瓶满的，
喝完以后4个空瓶子，用3个再换一瓶，喝掉这瓶满的，这时候剩2个空瓶子。然后你让老板先借
给你一瓶汽水，喝掉这瓶满的，喝完以后用3个空瓶子换一瓶满的还给老板。如果小张手上有n个
空汽水瓶，最多可以换多少瓶汽水喝？

输入描述:
输入文件最多包含10组测试数据，每个数据占一行，仅包含一个正整数n（1<=n<=100），
表示小张手上的空汽水瓶数。n=0表示输入结束，你的程序不应当处理这一行。

输出描述:
对于每组测试数据，输出一行，表示最多可以喝的汽水瓶数。如果一瓶也喝不到，输出0。

示例1
输入
3
10
81
0
输出
1
5
40
 */
public class 汽水瓶 {

    public static void main(String[] args) {
        System.out.println(drink(10));
    }

    public static int drink(int n) {
        //设最多能换total瓶饮料
        int total = 0;
        //当n>2时才进行喝饮料从、产生空瓶，并将空瓶数和total值累加
        while (n > 2) {
            total += n / 3;
            n = n / 3 + n % 3;
        }
        //当空瓶数等于2时，可以向商店借一瓶饮料，total加1
        if (n == 2) {
            total++;
        }
        return total;
    }

}
